home *** CD-ROM | disk | FTP | other *** search
Wrap
<?php /* +-------------------------------------------------------------------------- | IBFORUMS v1 | ======================================== | by Matthew Mecham and David Baxter | (c) 2001,2002 IBForums | http://www.ibforums.com | ======================================== | Web: http://www.ibforums.com | Email: phpboards@ibforums.com | Licence Info: phpib-licence@ibforums.com +--------------------------------------------------------------------------- | | > Import functions | > Module written by Matt Mecham | > Date started: 22nd April 2002 | | > Module Version Number: 1.0.0 +-------------------------------------------------------------------------- */ // Ensure we've not accessed this script directly: $idx = new ad_modlogs(); class ad_modlogs { var $base_url; function ad_modlogs() { global $IN, $root_path, $INFO, $DB, $SKIN, $ADMIN, $std, $MEMBER, $GROUP; switch($IN['code']) { case 'view': $this->view(); break; case 'remove': $this->remove(); break; //------------------------- default: $this->list_current(); break; } } //--------------------------------------------- // Remove archived files //--------------------------------------------- function view() { global $IN, $root_path, $INFO, $DB, $SKIN, $ADMIN, $std, $MEMBER, $GROUP; $start = $IN['st'] ? $IN['st'] : 0; $ADMIN->page_detail = "Viewing all actions by a moderator"; $ADMIN->page_title = "Moderator Logs Manager"; if ($IN['search_string'] == "") { $DB->query("SELECT COUNT(id) as count FROM ibf_moderator_logs WHERE member_id='".$IN['mid']."'"); $row = $DB->fetch_row(); $row_count = $row['count']; $query = "&act=modlog&mid={$IN['mid']}&code=view"; $DB->query("SELECT m.*, f.id as forum_id, f.name FROM ibf_moderator_logs m, ibf_forums f WHERE m.member_id='".$IN['mid']."' AND f.id=m.forum_id ORDER BY m.ctime DESC LIMIT $start, 20"); } else { $IN['search_string'] = urldecode($IN['search_string']); if ( ($IN['search_type'] == 'topic_id') or ($IN['search_type'] == 'forum_id') ) { $dbq = "m.".$IN['search_type']."='".$IN['search_string']."'"; } else { $dbq = "m.".$IN['search_type']." LIKE '%".$IN['search_string']."%'"; } $DB->query("SELECT COUNT(m.id) as count FROM ibf_moderator_logs m WHERE $dbq"); $row = $DB->fetch_row(); $row_count = $row['count']; $query = "&act=modlog&code=view&search_type={$IN['search_type']}&search_string=".urlencode($IN['search_string']); $DB->query("SELECT m.*, f.id as forum_id, f.name FROM ibf_moderator_logs m, ibf_forums f WHERE $dbq AND f.id=m.forum_id ORDER BY m.ctime DESC LIMIT $start, 20"); } $links = $std->build_pagelinks( array( 'TOTAL_POSS' => $row_count, 'PER_PAGE' => 20, 'CUR_ST_VAL' => $start, 'L_SINGLE' => "Single Page", 'L_MULTI' => "Pages: ", 'BASE_URL' => $ADMIN->base_url.$query, ) ); $ADMIN->page_detail = "You may view and remove actions performed by your moderators"; $ADMIN->page_title = "Moderator Logs Manager"; //+------------------------------- $SKIN->td_header[] = array( "Member Name" , "15%" ); $SKIN->td_header[] = array( "Action Perfomed" , "15%" ); $SKIN->td_header[] = array( "Forum" , "15%" ); $SKIN->td_header[] = array( "Topic Title" , "25%" ); $SKIN->td_header[] = array( "Time of action" , "20%" ); $SKIN->td_header[] = array( "IP address" , "10%" ); $ADMIN->html .= $SKIN->start_table( "Saved Moderator Logs" ); $ADMIN->html .= $SKIN->add_td_basic($links, 'center', 'catrow'); if ( $DB->get_num_rows() ) { while ( $row = $DB->fetch_row() ) { $row['ctime'] = $std->get_date( $row['ctime'], 'LONG' ); $sess_id = preg_replace( "/^.+?s=(\w{32}).+?$/" , "\\1", $row['http_referer'] ); $row['http_referer'] = preg_replace( "/s=(\w){32}/" , "" , $row['http_referer'] ); $ADMIN->html .= $SKIN->add_td_row( array( "<b>{$row['member_name']}</b>", "<span style='font-weight:bold;color:red'><a href='#' onClick=\"alert('HTTP REFERRER OF ACTION:\\n{$row['http_referer']}\\nSESSION ID OF ACTION:\\n$sess_id')\">{$row['action']}</a></span>", "<b>{$row['name']}</b>", "{$row['topic_title']}", "{$row['ctime']}", "{$row['ip_address']}", ) ); } } else { $ADMIN->html .= $SKIN->add_td_basic("<center>No results</center>"); } $ADMIN->html .= $SKIN->add_td_basic($links, 'center', 'tdtop'); $ADMIN->html .= $SKIN->end_table(); //+------------------------------- //+------------------------------- $ADMIN->output(); } //--------------------------------------------- // Remove archived files //--------------------------------------------- function remove() { global $IN, $root_path, $INFO, $DB, $SKIN, $ADMIN, $std, $MEMBER, $GROUP; if ($IN['mid'] == "") { $ADMIN->error("You did not select a member ID to remove by!"); } $DB->query("DELETE FROM ibf_moderator_logs WHERE member_id='".$IN['mid']."'"); $std->boink_it($ADMIN->base_url."&act=modlog"); exit(); } //------------------------------------------------------------- // SHOW ALL LANGUAGE PACKS //------------------------------------------------------------- function list_current() { global $IN, $root_path, $INFO, $DB, $SKIN, $ADMIN, $std, $MEMBER, $GROUP; $form_array = array(); $ADMIN->page_detail = "You may view and remove actions performed by your moderators"; $ADMIN->page_title = "Moderator Logs Manager"; //+------------------------------- $SKIN->td_header[] = array( "Member Name" , "30%" ); $SKIN->td_header[] = array( "Actions Perfomed" , "20%" ); $SKIN->td_header[] = array( "View all by member" , "20%" ); $SKIN->td_header[] = array( "Remove all by member" , "30%" ); $ADMIN->html .= $SKIN->start_table( "Saved Moderator Logs" ); $DB->query("SELECT m.*, count(m.id) as act_count from ibf_moderator_logs m GROUP BY m.member_id ORDER BY act_count DESC"); while ( $r = $DB->fetch_row() ) { $ADMIN->html .= $SKIN->add_td_row( array( "<b>{$r['member_name']}</b>", "<center>{$r['act_count']}</center>", "<center><a href='".$SKIN->base_url."&act=modlog&code=view&mid={$r['member_id']}'>View</a></center>", "<center><a href='".$SKIN->base_url."&act=modlog&code=remove&mid={$r['member_id']}'>Remove</a></center>", ) ); } $ADMIN->html .= $SKIN->end_table(); //+------------------------------- //+------------------------------- $ADMIN->html .= $SKIN->start_form( array( 1 => array( 'code' , 'view' ), 2 => array( 'act' , 'modlog' ), ) ); $SKIN->td_header[] = array( " " , "40%" ); $SKIN->td_header[] = array( " " , "60%" ); $ADMIN->html .= $SKIN->start_table( "Search Moderator Logs" ); $form_array = array( 0 => array( 'topic_title', 'Topic Title' ), 1 => array( 'ip_address', 'IP Address' ), 2 => array( 'member_name', 'Member Name' ), 3 => array( 'topic_id' , 'Topic ID' ), 4 => array( 'forum_id' , 'Forum ID' ) ); //+------------------------------- $ADMIN->html .= $SKIN->add_td_row( array( "<b>Search for...</b>" , $SKIN->form_input( "search_string") ) ); $ADMIN->html .= $SKIN->add_td_row( array( "<b>Search in...</b>" , $SKIN->form_dropdown( "search_type", $form_array) ) ); $ADMIN->html .= $SKIN->end_form("Search"); $ADMIN->html .= $SKIN->end_table(); //+------------------------------- //+------------------------------- $ADMIN->output(); } } ?>